<script lang="ts">
	import { fade } from 'svelte/transition';
	import { getDevices, removeDevice } from '$lib/common/apiFunctions.svelte';
	import { deviceStore, alertStore } from '$lib/common/stores.js';
	import { Device } from '$lib/common/classes';

	export let device = new Device();
	let cardDeleting = false;

	function removeDeviceAction() {
		removeDevice(device.id)
			.then((response) => {
				cardDeleting = false;
				// refresh Devices after editing
				getDevices();
			})
			.catch((error) => {
				$alertStore = error;
			});
	}
</script>

{#if !cardDeleting}
	<!-- Delete trash symbol -->
	<button on:click|stopPropagation={() => (cardDeleting = true)} class="mr-4"
		><svg xmlns="http://www.w3.org/2000/svg" class="h-6 w-6 inline flex-shrink-0" fill="none" viewBox="0 0 24 24" stroke="currentColor" stroke-width="2">
			<path stroke-linecap="round" stroke-linejoin="round" d="M19 7l-.867 12.142A2 2 0 0116.138 21H7.862a2 2 0 01-1.995-1.858L5 7m5 4v6m4-6v6m1-10V4a1 1 0 00-1-1h-4a1 1 0 00-1 1v3M4 7h16" />
		</svg></button
	>
{:else}
	<!-- Delete Warning -->
	<span in:fade|global class="font-bold text-red-400">Deleting {device.name}. Confirm </span>
	<!-- Delete confirm symbol -->
	<button in:fade|global on:click|stopPropagation={() => removeDeviceAction()}
		><svg xmlns="http://www.w3.org/2000/svg" class="h-6 w-6 inline flex-shrink-0" fill="none" viewBox="0 0 24 24" stroke="currentColor" stroke-width="2">
			<path stroke-linecap="round" stroke-linejoin="round" d="M9 12l2 2 4-4m6 2a9 9 0 11-18 0 9 9 0 0118 0z" />
		</svg></button
	>
	<span in:fade|global class="font-bold text-red-400">or Cancel </span>
	<!-- Delete cancel symbol -->
	<button in:fade|global on:click|stopPropagation={() => (cardDeleting = false)} class="mr-4"
		><svg xmlns="http://www.w3.org/2000/svg" class="h-6 w-6 inline flex-shrink-0" fill="none" viewBox="0 0 24 24" stroke="currentColor" stroke-width="2">
			<path stroke-linecap="round" stroke-linejoin="round" d="M10 14l2-2m0 0l2-2m-2 2l-2-2m2 2l2 2m7-2a9 9 0 11-18 0 9 9 0 0118 0z" />
		</svg></button
	>
{/if}
